import java.util.*;

public class Sieve {

    public static void main(String[] args) {

        int n = 2000000;
        long start = System.currentTimeMillis();

        int i, count = 0;
        BitSet b = new BitSet(n + 1);

        for (i = 2; i <= n; i++)
            b.set(i);
        i = 2;

        while (i * i <= n) {
            if (b.get(i)) {
                count++;
                int k = 2 * i;
                while (k <= n) {
                    b.clear(k);
                    k += i;
                }
            }
            i++;
        }

        while (i <= n) {
            if (b.get(i)) count++;
            i++;
        }

        long end = System.currentTimeMillis();
        System.out.println(count + " primes");
        System.out.println((end - start) + " milliseconds");
    }
}
